home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Sprite 1984 - 1993
/
Sprite 1984 - 1993.iso
/
src
/
lib
/
c
/
stdio
/
RCS
/
fgetc.c,v
< prev
next >
Wrap
Text File
|
1991-12-02
|
3KB
|
113 lines
head 1.1;
branch ;
access ;
symbols sprited:1.1.1;
locks ; strict;
comment @ * @;
1.1
date 88.06.10.16.23.43; author ouster; state Exp;
branches 1.1.1.1;
next ;
1.1.1.1
date 91.12.02.19.56.09; author kupfer; state Exp;
branches ;
next ;
desc
@@
1.1
log
@Initial revision
@
text
@/*
* fgetc.c --
*
* Source code for the "fgetc" library procedure.
*
* Copyright 1988 Regents of the University of California
* Permission to use, copy, modify, and distribute this
* software and its documentation for any purpose and without
* fee is hereby granted, provided that the above copyright
* notice appear in all copies. The University of California
* makes no representations about the suitability of this
* software for any purpose. It is provided "as is" without
* express or implied warranty.
*/
#ifndef lint
static char rcsid[] = "$Header: atoi.c,v 1.1 88/04/28 17:20:23 ouster Exp $ SPRITE (Berkeley)";
#endif not lint
#include "stdio.h"
/*
*----------------------------------------------------------------------
*
* fgetc --
*
* This procedure returns the next input character from a stream.
* It's a procedural version of the getc macro, and also
* gets invoked by getc when the buffer needs to be refilled.
*
* Results:
* The result is an integer value that is equal to EOF if an end
* of file or error condition was encountered on the stream.
* Otherwise, it is the value of the next input character from
* stream.
*
* Side effects:
* A character is removed from stream.
*
*----------------------------------------------------------------------
*/
int
fgetc(stream)
register FILE *stream; /* Stream from which to read character. */
{
if (!(stream->flags & STDIO_READ)) {
return(EOF);
}
while (stream->readCount <= 0) {
if ((stream->status != 0) || (stream->flags & STDIO_EOF)) {
return(EOF);
}
/*
* If the stream has been getting used for writing lately,
* "turn it around" by flushing the write data. Then read
* in a buffer-full of read data.
*/
if ((stream->writeCount > 0)
&& (stream->lastAccess >= stream->buffer)) {
(*stream->writeProc)(stream, 1);
stream->writeCount = 0;
}
(*stream->readProc)(stream);
}
stream->readCount--;
stream->lastAccess++;
return *stream->lastAccess;
}
@
1.1.1.1
log
@Initial branch for Sprite server.
@
text
@d17 1
a17 1
static char rcsid[] = "$Header: /sprite/src/lib/c/stdio/RCS/fgetc.c,v 1.1 88/06/10 16:23:43 ouster Exp $ SPRITE (Berkeley)";
@